

# Computer Architecture and Assembly Language Lab Fall 2016

#### Lab 4

# CPU Structure, Pipeline Programming and Hazards, Exceptions and Interrupts

#### Goal

After completing this lab, you will:

| Know the difference between pipelined and no-pipelined processors         |
|---------------------------------------------------------------------------|
| Learn how the pipeline works; know how to prevent hazards in the pipeline |
| Know the exception mechanism in MIPS                                      |

☐ Be able to write an interrupt handler for a MIPS machine

# **Preparation**

Please read Chapter 4 and Appendices A.7 and A.8in the textbook. This knowledge is required for this lab.

#### Introduction

A CPU has 5 basic components, the Arithmetic and Logical Unit (ALU), the Instruction Memory, the Register File, the Data Memory and its Control. The ALU is responsible for executing the arithmetic functions, such as addition, multiplication, subtraction, and the logical functions, e.g. AND, OR, logical shift etc. The instruction memory is the memory where an assembly program is stored before execution. The Register File contains the state of the processor. The data memory is the memory where all the data produced or not are stored. Finally, the control is responsible for decoding an instruction and



setting all necessary control signals with the proper value. In figure 1 a diagram of this simple CPU is shown. Computers execute instructions in a serial manner. A way to speed up a program's execution is by using Pipeline. Pipeline is a method to increase the throughput of the executing instruction without actually affecting the time a single instruction needs to execute. Finally, control is the most challenging aspect of processor design: it is both the hardest part to get right and the hardest part to make fast. One of the difficult parts of control design is implementing *exceptions* and *interrupts*. An exception is an unscheduled event that disrupts program execution. An interrupt is an exception that comes from outside of the processor [1].

#### **CPU Structure**

In order to examine the structure of the MIPS CPU, the implementation of actual instructions must be analyzed, so that the organization of the memory, the ALU and the control of the CPU are understood. In figure 1, an overview of the parts of a CPU is depicted. The most important parts are:

- 1. The Program Counter (PC) points to the position where the instruction that is to be executed in the instruction memory.
- 2. The Registers contain the state of the processor in every clock cycle.
- 3. The Arithmetic and Logical Unit (ALU) is responsible to execute every arithmetic or logical operation that is needed or each command.
- 4. The Data Memory contains all the data that either are generated by the execution if the instructions or are the initial data that a program may need.
- 5. The Instruction Memory where the compiled and linked instructions are stores before execution.
- 6. The Control of the processor decodes each instruction and sets all the control signals according to the instruction.
- 7. The ALU control is responsible to pass the correct control signal to the ALU according to the arithmetic or logical operation that is requested by the Control unit.

In order to understand how an instruction is executed and how the datapath operates, two examples will be given, the first explaining the instruction *add* \$t1, \$t2, \$t3 and the second the second the instruction *lw* \$t1, offset(\$t2). Table 1 shows the values the control signals have for the two examples.

Example 1 add \$t1, \$t2, \$t3



### The execution can be shown in four steps [1]:

- 1. The instruction is fetched and the PC is incremented.
- 2. Two registers, \$t2 and \$t3, are read from the register file. Also, the main control unit computes the setting of the control lines.
- 3. The ALU operates on the data read from the register file, using the function code (bits :0 of the instruction) to generate the ALU function.
- 4. The result of the ALU is written into the register file using the bits 15:11 of the instruction to select the destination register \$t1.

# Example 2 lw \$t1, offset(\$t2)

#### The execution can be shown in 5 steps [1]:

- 1. The instruction is fetched and the PC is incremented.
- 2. A register (\$t2) value is read from the register file.
- 3. The ALU computes the sum of the value read from the register file and the signextended, lower 16 bits of the instruction (*offset*).
- 4. The sum of the ALU is used as the address for the data memory.
- 5. The data from the memory unit is written into the register file; the register destination is given by bits 20:16 of the instruction (\$t1).

| Instruction           | RegDst | ALUSrc | MemtoReg | RegWrite | MemRead | MemWrite | Brach | ALUOp [1:0] |
|-----------------------|--------|--------|----------|----------|---------|----------|-------|-------------|
| add \$t1, \$t2, \$t3  | 1      | 0      | 0        | 1        | 0       | 0        | 0     | 10          |
| lw \$t1, offset(\$t2) | 0      | 1      | 1        | 1        | 1       | 0        | 0     | 00          |

Table 1 The setting of the control lines of examples 1 and 2 based on figure 1





Figure 1 The simple datapath with the control unit

The explanation of the control signals is as follows:

| Signal<br>Name | Explanation                                                                                                                                  |      |  |  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|------|--|--|--|--|
| RegDst         | Selects the register destination number either from rt field (bits 20:16) or the rd field (15:11) of the instruction                         | bits |  |  |  |  |
| ALUSrc         | Selects the second input of the ALU either from the second output of the register file or the sign extended lower 16 bits of the instruction |      |  |  |  |  |



| MemtoReg   | Selects the data fed to the register Write data input either from the ALU output or the data memory output |  |  |  |  |  |  |
|------------|------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| RegWrite   | The register on the Write register input is written with the value on the Write data input                 |  |  |  |  |  |  |
| MemRead    | Data memory contents designated by the address input are put on the Read data output                       |  |  |  |  |  |  |
| MemWrite   | Data memory contents designated by the address input are replaced by the value on the Write data input     |  |  |  |  |  |  |
| Branch     | Indicates if the instruction is a branch instruction                                                       |  |  |  |  |  |  |
| ALUOp[1:0] | The ALU operation. See Figure 4.12 of the text book, pp 260                                                |  |  |  |  |  |  |

#### **Pipeline Programming and Hazards**

When a processor supports pipeline, an instruction can be divided in four or five steps which are 1) Instruction Fetch [IF], 2) Instruction Decode [ID], 3) Execution [EX], 4) Data Memory Access [MEM] and 5) Write Back the result to the register file [WB]. For a processor to achieve its maximum throughput the pipeline must always be kept full. Also, the clock cycle time is defined by the slowest step of an instruction.

Let us now see an example. Consider 3 consecutive instructions A, B and C. Each instruction has the above-mentioned five steps. When a processor does not support pipeline each instruction will be executed after the previous one has finished, as it is shown in Table 2. Also, suppose that instruction A start at cycle 1

| Instr/Cycle | 1  | 2  | 3  | 4   | 5  | 6  | 7  | 8  | 9   | 10 | 11 | 12 | 13 | 14  | 15 |
|-------------|----|----|----|-----|----|----|----|----|-----|----|----|----|----|-----|----|
| Α           | IF | ID | EX | MEM | WB |    |    |    |     |    |    |    |    |     |    |
| В           |    |    |    |     |    | IF | ID | EX | MEM | WB |    |    |    |     |    |
| С           |    |    |    |     |    |    |    |    |     |    | IF | ID | EX | MEM | WB |

**Table 2 Instruction Execution without Pipeline** 

On the other hand, when pipeline is supported each instruction can start executing even though the previous one has not necessarily finished. Table 3 shows this scheme. Again, instruction A starts executing in cycle 1.



| Inst/Cycle | 1  | 2  | 3  | 4   | 5   | 6   | 7  | 8 |
|------------|----|----|----|-----|-----|-----|----|---|
| Α          | IF | ID | EX | MEM | WB  |     |    |   |
| В          |    | IF | ID | EX  | MEM | WB  |    |   |
| С          |    |    | IF | ID  | EX  | MEM | WB |   |

Table 3 Instruction Execution with pipeline support

There are, though, situations in the pipelining when the next instruction cannot execute in the following clock cycle. These events are called Hazards and there are three different types [1]:

- A. Structural Hazard. When a planned instruction cannot execute in the proper clock cycle because the hardware does not support the combination of instructions that are set to execute [1].
- B. Data Hazard or Pipeline Data Hazard. When a planned instruction cannot execute in the proper clock cycle because data that is needed to execute the instruction is not yet available [1].
- C. Control Hazard or Branch Hazard. When the proper instruction cannot execute in the proper pipeline clock cycle because the instruction that was fetched is not the one that is needed; that is, the flow of instruction addresses is not what the pipeline expected [1].

To understand a Data Hazard, consider the following code fragment:

lb \$t0, 1(\$t1)

add \$t2, \$t0, \$t1

The execution of the code with pipeline support is as follows:

| Instr/Cycle          | 1  | 2  | 3  | 4   | 5   | 6  |
|----------------------|----|----|----|-----|-----|----|
| lb \$t0, 1(\$t1)     | IF | ID | EX | MEM | WB  |    |
| add \$t2, \$t0, \$t1 |    | IF | ID | EX  | MEM | WB |

The *lb* will write the value from the memory in the register file in step WB, in the mean time the *add* will have retrieved its operands in the ID step. This actually means that the old value of register \$t0 will be used for the addition.

Such hazards can be prevented by either writing a program that does not provoke any hazard or by



adding an ample number of no-operation instructions (NOP) between the instructions that depend on the result of each other. NOP operations act like bubbles inside the pipeline delaying the execution of the second instruction (and subsequent instructions) until the values it requires as input are ready. When the NOP technique is used in the above example, the following happens:

| Instr/Cycl           | 1  | 2  | 3     | 4     | 5  | 6  | 7   | 8  |
|----------------------|----|----|-------|-------|----|----|-----|----|
| lb \$t0, 1(\$t1)     | IF | ID | EX    | MEM   | WB |    |     |    |
| add \$t2, \$t0, \$t1 |    | IF | Stall | Stall | ID | EX | MEM | WB |

An alternative technique to the use of NOP operations is Instruction Forwarding. In this technique, the result of an instruction will be sent forward to the next instruction before it is written back to the register file and it is possible that stalling is not fully needed. The above example can become as the following with instruction forwarding:

| Instr/Cycl           | 1  | 2  | 3     | 4   | 5  | 6   | 7  | 8 |
|----------------------|----|----|-------|-----|----|-----|----|---|
| lb \$t0, 1(\$t1)     | IF | ID | EX    | MEM | WB |     |    |   |
| add \$t2, \$t0, \$t1 |    | IF | Stall | ID  | EX | MEM | WB |   |

It can be easily seen that a Stall cycle still exists. The reason is that the *lb* instruction will not have the data ready for use before it is read from the memory. When it writes back the value in the register file, it also forwards it to the input of the ALU for immediate use. If that stall does not exist even with instruction forwarding the forwarded result would arrive too late and the result of the *add* instruction would be wrong.

The third technique that a programmer can use to avoid data hazards is "Instruction Reordering". As it implied by its name, the independence between instructions can be exploited in order to reorder them in a way that keeps the pipeline as full as possible.

Consider the following code segment:

Iw \$t0, 0(\$t1) addi \$t2, \$t0, 2 subi \$t3, \$t4, 2



Without instruction reordering the execution will be the following:

| Instr/Cycle        | 1  | 2  | 3     | 4     | 5     | 6  | 7   | 8   | 9  |
|--------------------|----|----|-------|-------|-------|----|-----|-----|----|
| lw \$t0, 0(\$t1)   | IF | ID | EX    | MEM   | WB    |    |     |     |    |
| add \$t2, \$t0, 2  |    | IF | Stall | Stall | ID    | EX | MEM | WB  |    |
| subi \$t3, \$t4, 2 |    |    | IF    | Stall | Stall | ID | EX  | MEM | WB |

It is clear that two cycles are lost due to the NOP instructions. Also, it is easily seen that *subi* does not need the result of the *lw* or the *add*. In this case *subi* is independent of the other two and it can be move between them. After reordering the execution will look like this:

| Instr/Cycle        | 1  | 2  | 3  | 4     | 5   | 6  | 7   | 8  |
|--------------------|----|----|----|-------|-----|----|-----|----|
| lw \$t0, 0(\$t1)   | IF | ID | EX | MEM   | WB  |    |     |    |
| subi \$t3, \$t4, 2 |    | IF | ID | EX    | MEM | WB |     |    |
| add \$t2, \$t0, 2  |    |    | IF | Stall | ID  | EX | MEM | WB |

#### **Exceptions and Interrupts**

The MIPS convention calls an *exception* any unexpected change in control flow regardless of its source (i.e. without distinguishing between a cause within the processor and an external cause).

# □ The MIPS exception mechanism[3]

The method implemented by the MIPS designers to interrupt the currently running program is to include some additional hardware referred to as **coprocessor 0**. This coprocessor contains a number of specialized registers that can be accessed at the assembly language level for exception handling. The top window of the *QtSpim* simulator displays these registers:

٠



| Register<br>Number in<br>coprocessor 0 | Register<br>Name | Usage                                                           |
|----------------------------------------|------------------|-----------------------------------------------------------------|
| 8                                      | BadVAddr         | Virtual Memory address where exception occurred                 |
| 12                                     | Status           | Interrupt mask, enable bits, and status when exception occurred |
| 13                                     | Cause            | Type of exception and pending interrupt bits                    |
| 14                                     | EPC              | Address of instruction that caused exception                    |

The BadVAddr (Bad Virtual Address) register will contain the memory address where the exception has occurred. An unaligned memory access, for instance, will generate an exception and the address where the access was attempted will be stored in BadVAddr.



Figure 2 The layout of the Cause Register

The Cause register provides information about the level of pending interrupts (IP2 to IP7) and the cause of the exception. The exception code is stored as an unsigned integer using bits 6-2 in the Cause register. The layout of the Cause register is presented above.

Bit *IPi* becomes 1 if an interrupt has occurred at level *i* and is pending (has not been serviced yet). The bits *IP1* and *IP0* are used for simulated interrupts that can be generated by software. The exception code indicates what caused the exception.

| Number | Name | Cause of exception                                  |
|--------|------|-----------------------------------------------------|
| 0      | Int  | Interrupt (Hardware)                                |
| 4      | AdEL | Address Error Exception (load or instruction fetch) |
| 5      | AdES | Address Error Exception (store)                     |



| 6  | IBE | Bus Error on Instruction Fetch  |
|----|-----|---------------------------------|
| 7  | DBE | Bus Error on data load or store |
| 8  | Sys | Syscall Exception               |
| 9  | Вр  | Breakpoint Exception            |
| 10 | RI  | Reserved Instruction Exception  |
| 11 | CpU | Coprocessor Unimplemented       |
| 12 | Ov  | Arithmetic Overflow Exception   |
| 13 | Tr  | Trap                            |
| 15 | FPE | Floating Point                  |

**Table 4 Exception codes supported by SPIM** 

**The Status register** contains an interrupt mask on bits 15-10 and status information on bits 5-0. The layout of the Status register is presented below.



Figure 3 The layout of the Status Register

The interrupt mask field contains a bit for each of the six hardware and two software interrupt levels. If a mask bit is 1, interrupts are allowed at that level. For an interrupt to interrupt the processor both the pending bit in the Cause register and the mask bit must be enabled. The



user mode bit is 0 if the processor runs in kernel mode and 1 when it runs in user mode. The exception bit becomes 1 when an exception has occurred, otherwise is 0. The interrupt enable bit is 1 when interrupts are allowed, otherwise it is 0 [1].

**The EPC register**, when a procedure is called using jal, two things happen:

- Control is transferred to the address provided by the instruction
- The return address is saved in the return address register \$ra

In the case of an exception there is no explicit call. In MIPS the control is transferred at a fixed location, 0x80000180 when an exception occurs. The exception handler must be located at that address. The **Exception Program Counter** (EPC) is used to store the address of the instruction that was executing when the exception was generated.

The CPU operates in one of the two possible modes, **user** and **kernel**. User programs run in user mode. The CPU enters the kernel mode when an exception happens. **Coprocessor 0** can only be used in kernel mode. When running in kernel mode the registers of coprocessor 0 can be accessed using the following instructions:

| Instruction          | Comment                                                    |  |  |  |  |  |  |  |  |
|----------------------|------------------------------------------------------------|--|--|--|--|--|--|--|--|
| mfc0 Rdest, C0src    | Move the content of coprocessor's register cosrc to        |  |  |  |  |  |  |  |  |
|                      | Rdest                                                      |  |  |  |  |  |  |  |  |
| mtc0 Rsrc, C0dest    | Integer register Rsrc is moved to coprocessor's register   |  |  |  |  |  |  |  |  |
|                      | C0dest (Be careful! The destination is the right-hand one) |  |  |  |  |  |  |  |  |
| lwc0 C0dest, address | Load word from address into register COdest                |  |  |  |  |  |  |  |  |
| swc0 C0src, address  | Store the content of register C0src to address in          |  |  |  |  |  |  |  |  |
|                      | memory                                                     |  |  |  |  |  |  |  |  |

Table 5 Instructions for accessing coprocessor 0 registers



#### Assignment 1

Suppose you have the CPU of Figure 1 and that there is not any pipeline scheme. For the following program indicate the values of the control signals for each instruction.

```
addiu $t0, 10

Ib $t1, 32($t0)

or $t2, $t0, $t1

bne $t2, $t0, QUIT

j 2500
```

#### Assignment 2

Suppose you have a machine that supports the five pipeline stages mentioned above. Using the following programs to answer the questions:

*Iw \$t0, 0(\$t3)* 

add \$t1, \$t0, \$t2

sub \$t3, \$t3, \$t1

addi \$t4, \$t4, 4

sub \$t5, \$t5, \$t4

- 1. Complete the table of execution with five pipeline stages. Ignore all hazards.
- 2. Suppose that register \$t0, \$t1, \$t2, \$t3, and \$t4 have the respective values of 2, 5, 8, 2, and 4. Give the values of the registers after running the program without the processor handling any hazards.
- 3. Insert the necessary NOP instructions so that the registers would get the values as when the processor executes the program one instruction per cycle.
- 4. Discuss how instruction reordering can avoid the hazards in the code section above.
- 5. Discuss how forwarding can affects the execution of the code section above.



Compare it with NOP and instruction reordering.

#### **Assignment** 3

Consider the following code:

addiu \$t0,3 loop: \$t0, \$t0, 1 bne \$t0, \$zero, loop

- 1. Determine how many cycles would it take for the program to execute without hazards handling.
- 2. Draw the execution table and determine the type of hazards.
- 3. Write program using NOP instructions to avoid the hazards.
- 4. Describes the effects of instruction forwarding to this code.

#### Assignment 4

File "io.s" lets you read characters from and echo characters to the console by using interrupts and polling. When you run the program, you need to run it step by step and try to see the changes in the Status and Cause Registers (they can be found on the top left of QtSPIM).

Enable the memory-mapped I/O, load the file "io.s" and run the program. When running it, write to the console 6 lines of numbers or text. For example:

This Is Computer Architecture Lab 4

Try to see the changes that occur. Write your observations and discuss what the differences between polling and interrupts are. Explain how the interrupts are enabled. Are the interrupts enabled or disabled during polling? Include what would happen if they were enabled. Also, check the registers that save the changes before and after executing the exception. Analyze the exception response code.

Note: Before doing this assignment, read Appendix A of the manual. In Appendix B you will find the ASCII codes for all the characters.



#### Assignment 5

File "quad\_sol.s" contains a quadratic polynomial solver, which calculates the integer solution of a quadratic polynomial equation.

- 1. Rewrite the program using instructions reordering to reduce the number of cycles needed to execute the program. Indicate the number of cycle reduction.
- 2. Describe how forwarding would affect the execution of the program.

## **Experiment report**

Write a proper report including your codes, results (snapshot of output) and the conclusion of assignments and convert it to **pdf** format. Please also attach the **code** files (\*.s,\*.asm) to **Sakai** together with the report. Each lab report is **due** before the start of the next lab. Please include your name and Student ID in both report and the code.

#### References

- 1. Patterson and Hennessy, "Computer Organization and Design: The Hardware / Software interface", 5<sup>th</sup> Edition.
- 2. Daniel J. Ellard, "MIPS Assembly Language Programming: CS50 Discussion and Project Book", September 1994.
- 3. "Exceptions in MIPS", <a href="www.cs.iit.edu/~virgil/cs470/Labs/Lab7.pdf">www.cs.iit.edu/~virgil/cs470/Labs/Lab7.pdf</a>
- 4. "Low-level IO", http://courses.knox.edu/cs201/
- 5. Rabert Britton, "MIPS Assembly Language Programming", Pearson Education Inc. 2004



#### **APPENDIX A**

#### 1. SPIM Keyboard Input

The SPIM simulator for the MIPS processor has a device emulator that allows you to read characters from the keyboard. The keyboard I/O registers are mapped to the locations 0XFFFF0000 and 0XFFFF0004, called Receiver Control register and Receiver Data register respectively. The Receiver Control register has an input Ready bit – bit 0 – and an output Interrupt Enable bit – bit 1. If the Ready bit is 0, then there is no data waiting to be read from the keyboard, otherwise, if the Ready bit is 1, then there is data to be read from the keyboard. If the Interrupt Enable bit is set to 0, an interrupt is not triggered by the device. On the other hand, if the Interrupt Enable bit is set to 1, an interrupt is triggered whenever new data is ready to be read. The last byte of the Receiver Data register is an input byte representing the key pressed. When the Receiver Data register is read, it also sets the Ready bit to 0 until a new byte is received.



**Figure 4 The Receiver Control and Data registers** 

#### 2. SPIM Terminal Output

The SPIM simulator for the MIPS processor has a device emulator that allows you to send characters to a terminal. The terminal I/O registers are mapped to the locations 0xFFFF0008 and 0xFFFF000C, which are called Transmitter Control register and Transmitter Data register respectively. The Transmitter Control register consists of an input Ready bit – bit 0 – and an output Interrupt Enable bit – bit 1. If the Ready bit is 0, then the terminal is not ready to receive any data, otherwise, if it is 1, the terminal is accepting data. If the Interrupt Enable bit is set to 0, an interrupt is not triggered by the device, otherwise if it set to 1 an interrupt is triggered whenever the terminal is accepting new data. The last byte of the Transmitter Data register is an output byte representing the data being send to the



terminal. When a byte is written to the Transmitter data register, it sets the ready bit to 0 until a new byte is ready to be sent.



Figure 5 The Transmitter Control and Data registers

3. In order to enable the memory-mapped I/O you need to find the Setting command under the Simulator menu. In the MIPS tab of the QtSPIM Setting window check the box "Enable Mapped IO".





# **APPENDIX B. ASCII Value Table**

| Dec | Н  | Oct | Cha | rs                       | Dec       | Нх         | Oct               | Html           | Chr   | Dec        | Нх         | Oct             | Html          | Chr | Dec                                       | Нх       | Oct        | Html CI | nr_ |
|-----|----|-----|-----|--------------------------|-----------|------------|-------------------|----------------|-------|------------|------------|-----------------|---------------|-----|-------------------------------------------|----------|------------|---------|-----|
| 0   | 0  | 000 | NUL | (null)                   | 32        | 20         | 040               |                | Space | 64         | 40         | 100             | a#64;         | 0   | 96                                        | 60       | 140        | a#96;   |     |
| 1   | 1  | 001 | SOH | (start of heading)       | 33        | 21         | 041               | @#33;          | 1     | 65         | 41         | 101             | A             | A   | 97                                        | 61       | 141        | 6#97;   | a   |
| 2   | 2  | 002 | STX | (start of text)          | 34        | 22         | 042               | @#34;          | rr    | 66         | 42         | 102             | B             | В   | 98                                        | 62       | 142        | 6#98;   | b   |
| 3   | 3  | 003 | ETX | (end of text)            | 35        | 23         | 043               | 6#35;          | #     | 67         | 43         | 103             | a#67;         | C   | 99                                        | 63       | 143        | 6#99;   | C   |
| 4   | 4  | 004 | EOT | (end of transmission)    | 50.5%     | VE 75      | 8 C / D / D       | \$             | 200   | 68         | 44         | 104             | D             | D   | 100                                       | 64       | 144        | d       | d   |
| 5   | 5  | 005 | ENQ | (enquiry)                | 37        | 25         | 045               | @#37;          | *     | 69         | 45         | 105             | <b>%#69</b> ; | E   | 5000 F000000                              |          |            | e       |     |
| 6   | 6  | 006 | ACK | (acknowledge)            | 1717.5    | 80717      | 225053            | &              |       | 70         | 200        |                 | <b>%#70</b> ; |     | J. S. |          | 7,000      | f       |     |
| 7   | 7  | 007 | BEL | (bell)                   | 39        | 27         | 047               | '              | 35    | 71         | 47         | 107             | 6#71;         | G   | 103                                       | 67       | 147        | g       | a   |
| 8   |    | 010 |     | (backspace)              | 40        | 28         | 050               | (              | 1     | 72         | 48         | 110             | 6#72;         | H   | 104                                       | 68       | 150        | h       | h   |
| 9   | 9  | 011 | TAB | (horizontal tab)         | 41        | 29         | 051               | )              | )     | 73         | 49         | 111             | 6#73;         | I   | 5-3000 C                                  | X2000    | 7 (300 500 | i       |     |
| 10  | A  | 012 | LF  | (NL line feed, new line) | 0.7750    | 200        | W7.55.73          | *              |       | 1005 V T-1 | 000,00     | N. 500000 575 A | a#74;         |     | 100 (F) (F)                               |          |            | j       | 200 |
| 11  | В  | 013 | VT  | (vertical tab)           | 0258      |            | v 5) T (5)        | 6#43;          | +     | 10.352     | 9855-V0    |                 | a#75;         |     | CT 17-10-0                                | 1000000  |            | k       |     |
| 12  | C  | 014 | FF  | (NP form feed, new page) | 44        | 20         | 054               | ,              |       | 76         | 1000       |                 | L             |     | G 50 50 50 50                             | 50.52    |            | l       |     |
| 13  | D  | 015 | CR  | (carriage return)        | 0.7350    | 200        | A- 1000C          | &# <b>4</b> 5; |       | 77         | B 27-18    | 10000           | 6#77;         |     | 500,000,000                               | VE 670   | 7.5-72     | m       |     |
| 14  | E  | 016 | S0  | (shift out)              | - 357775  | 2019000    |                   | .              |       | 78         | 857700     |                 | <b>%#78</b> ; |     | U7/05/07/14                               |          | 700        | n       |     |
| 15  | F  | 017 | SI  | (shift in)               | 100 5 700 |            | 80.750E-035       | 6#47;          | 100   | 79         | 277.0      | 3000000         | 6#79;         |     | 000000000000000000000000000000000000000   |          |            | o       |     |
| 16  | 10 | 020 | DLE | (data link escape)       | 48        | 30         | 060               | a#48;          | 0     | 80         | 50         | 120             | P             | P   | 112                                       | 70       | 160        | p       | p   |
| 17  | 11 | 021 | DC1 | (device control 1)       | 49        | 31         | 061               | 1              | 1     | 81         | 51         | 121             | Q             | Q   | 113                                       | 71       | 161        | q       | q   |
| 18  | 12 | 022 | DC2 | (device control 2)       | 0.00      |            |                   | 2              |       | 82         | T00 T2 (1) |                 | R             |     | TOTAL STREET                              | 731TSY   | TOTAL      | r       |     |
| 19  | 13 | 023 | DC3 | (device control 3)       | 199.57    |            | v 50500           | 3              |       | 2507       | 5050       |                 | 6#83;         |     | C                                         | 93. SM   |            | s       |     |
| 20  | 14 | 024 | DC4 | (device control 4)       | 100.000   | VII. 817.0 | 8 C 3 C 3 C 3 C 5 | 4              |       | 8.579.50   | 0.535      |                 | T             |     |                                           | 55 N. T. |            | t       |     |
|     |    |     |     | (negative acknowledge)   | 53        | 35         | 065               | a#53;          | 5     | 85         | 55         | 125             | <b>%#85</b> ; | U   | 117                                       | 75       | 165        | u       | u   |
| 22  | 16 | 026 | SYN | (synchronous idle)       | 54        | 36         | 066               |  <b>4</b> ;   | 6     | 86         | T00711     |                 | «#86;         |     | 118                                       | 76       | 166        | v       | V   |
| 23  | 17 | 027 | ETB | (end of trans. block)    | 55        | 37         | 067               | 7              | 7     | 87         | 57         | 127             | 6#87;         | W   | 119                                       | 77       | 167        | w       | W   |
| 24  | 18 | 030 | CAN | (cancel)                 | 56        | 38         | 070               | & <b>#</b> 56; | 8     | 88         | 58         | 130             | X             | X   | GT - TO TO -                              | 100 522  |            | x       |     |
| 25  | 19 | 031 | EM  | (end of medium)          | 57        | 39         | 071               | 9              | 9     | 89         | 59         | 131             | <b>%#89</b> ; | Y   | 121                                       | 79       | 171        | y       | Y   |
| 26  | 1A | 032 | SUB | (substitute)             | 58        | ЗA         | 072               | :              |       | 90         | 5A         | 132             | 6#90;         | Z   | 122                                       | 7A       | 172        | z       | Z   |
| 27  | 1B | 033 | ESC | (escape)                 | 59        | 3B         | 073               | ;              | ;     | 91         | 5B         | 133             | a#91;         | [   | 123                                       | 7B       | 173        | {       | 1   |
| 28  | 10 | 034 | FS  | (file separator)         | 60        | 30         | 074               | a#60;          | <     | 92         | 5C         | 134             | 6#92;         | 1   | 124                                       | 70       | 174        | a#124;  | 1   |
| 29  | 1D | 035 | GS  | (group separator)        | 61        | 3D         | 075               | =              | =     | 93         | 5D         | 135             | 6#93;         | ]   | 125                                       | 7D       | 175        | }       | }   |
| 30  | 1E | 036 | RS  | (record separator)       | 62        | 3E         | 076               | >              | >     | 94         | 5E         | 136             | a#94;         |     |                                           | - A      |            | ~       |     |
| 31  | 1F | 037 | US  | (unit separator)         | 63        | 3 <b>F</b> | 077               | <u>@</u> #63;  | 2     | 95         | 5F         | 137             | 6#95;         | _   | 127                                       | 7F       | 177        |         | DEL |